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(57) Abstract: A number of data collection devices (10. 20. 30, 40, 50, 60, 70, 80), are free to move relative to each other through 
their environment, collecting data from their environment. They form an ad hoc wireless network (19, 29, 39, 49), etc in which 
data collected by a device (20) either by its own sensors (23), or relayed from another device (10) is transmitted to a destination (90 
either directly or by means of one or more other devices (30). The destination (90) collects data collected by the mobile terminals 
(10, 20, 30) etc for subsequent processing. The wireless links (19, 29, 39) etc between them have to re-arranged in order to provide 
the optimum network. When two devices (20, 30) come into proximity to each other, a forwarding direction (200) is determined to 
identify to which device (30) data should be forwarded. The devices co-operate to define their forwarding directions by exchanging 
data relating to their physical locations, and factors such as the spare capacity of their buffer stores, and battery condition. Thus a 
network (19, 29, 39) etc will be defined dynamically, each device having its forwarding direction (200) aimed in the direction of the 
next device until they reach a sink. 
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Ad Hoc Communications System 

This invention relates to ad hoc networking applications, in which a number of 
5 communications devices co-operate to fom a communications networl^. There are two 
basic types, namely many-to-many communication, wherein the devices communicate 
mainly between themselves, and ad hoc edge networking, wherein the devices interface 
with conventional fixed networks through interface or edge devices. The communications 
devices form nodes of a wireless network, allowing data to be relayed from an originating 

10 communications device to a destination communications device, by way of other 
communications devices. Such devices have a number of applications in circumstances 
where the communications devices are likely to be moving in unpredictable ways. A 
particular application scenario is a sensor network, in which data is collected from a 
network of mobile sensor devices, each of which is capable of taking measurements and 

15 relaying packets of data. Such devices are used by scientists taking measurements of the 
behaviour of the atmosphere, the sea, ice caps, lava flows or wildlife. The environments in 
which such devices are required to operate often have measurement points widely 
dispersed in both space and time. Some of the environments are hostile to human life, in 
some applications^ such as the study of animal behaviour, human intervention could 

20 compromise the data. For these reasons the devices must be capable of operating 
autonomously, and transmitting the data they collect to a more convenient point using a 
wireless medium such as radio or sound. Moreover it is not usually possible to provide a 
continuous power supply, so the useful life of a device is primarily constrained by battery 
life. 

25 Other applications for such ad hoc networks, to which the invention might be 

applied, include ^'tagging" technology for monitoring the health of patients and the elderly 
in the community, or of the location of people subject to court orders restricting their 
movements. More generally, ad hoc networks can be made up of wireless laptop 
computers or mobile telephones in close proximity to each other. Military personnel, police 

30 or other emergency services could also use the invention when attending an incident 
where there are insufficient channels for all the users to communicate directly with the 
fixed base stations provided in the vicinity. In these cases, more conventional 
communication devices could become part of ad hoc wireless networks, exploiting short 
range transmissions and device relays towards an identified base station, or fixed network 

35 device. 



wo 2005/006668 



PCT/GB2004/001999 



2 

Many ad hoc routing protocols have been devised. Some of tlie most widely 
known are: 

- DSDV, described by C Perkins and P Bhagwat, Highly Dynamic Destinatlon-Sequenced 
Distance-Node pair Routing (DSDV) for mobile computers, Proceedings of the SIGCOMM 

5 '94 Conference on Communications Architectures, Protocols and Applications, pages 234- 
244, August 1994 

- TORA, described by VD Paric and MS Corson, A Highly Adaptive Distributed routing 
Algorithm for Mobile Wireless Networics, Proceedings oflNFOCOM '97, pages 1405-1413, 
April 1997 

10 - DSR, described by DB Johnson, Routing in Ad hoc Networtcs of Mobile Hosts, 
Proceedings of the IEEE Workshop on Mobile Computing Systems and Applications, 
pages 158-163, December 1994 

AODV, described by C Peri^ins, Ad hoc On Demand Distance Node pair (AODV) Routing, 
Internet-Draft, draft-ietf-manet-aod\/-04M, October 1999 

15 

DSDV maintains a routing table listing the next "hop" for each reachable destination. 
Routes are tagged with sequence numbers, with the most recently detemnined route, w'rth 
the highest sequence number, being the most favoured. There are periodic updates of 
routes and sequence numbers. TORA discovers routes on demand and gives multiple 

20 routes to a destination. Route query and update packets are sent for each destination. 
Although routes are established fairly quickly, there are often routing loops, leading to 
dropped packets. DSR uses source routing, rather than hop-by-hop routing, so each 
packet has a complete route, listed in its header. This protocol uses route discovery and 
route maintenance, with nodes maintaining caches of source routes that have been 

25 learned or overheard. AODV combines route discovery and route maintenance with hop- 
by-hop routing. Route request packets create reverse routes for themselves back to their 
source devices. "Hello" messages are periodically transmitted by the devices, so that 
neighbours are aware of the state of local links. 

A comparison of the performance of these protocols by J Broch, DA MaHz, DB 

30 Johnson, Y-C Hu, ("A Performance Comparison of Multi-Hop Wireless Ad Hoc Network 
Routing Protocols", Proceedings of the Fourth Annual ACM/IEEE International 
Conference on Mobile Computing and Networking, Mobicom '98, October 1 998, Dallas, 
Texas), has shown widely differing results in the size of routing overhead. The total 
overhead is greatest for TORA, and becomes unacceptably large for a network size of 

35 thirty source devices. 



wo 2005/006668 



PCT/GB2004/001999 



3 

Moreover, all of these prior art protocols require large processor and memory 
capacities, and their protocols do not take account of the energy usage required. Energy 
usage, along with memory and processor capacity, are particularly important in sensor 
networks. These typically consist of very small, very cheap microprocessors, e.g. 16 bit, 
5 with 32 kilobytes of RAM. They also have a finite battery supply, which would be 
impractical to replace given the nature of the applications in which the sensors are to be 
used. It is therefore very important that any communication protocol is energy-efficient 
aware, and also pared to a minimum in communication overhead and memory usage. In 
other applications, battery and memory usage are also important considerations: a user 

10 would be unwilling to allow his mobile telephone to fomn part of such an ad hoc network if 
other users caused a significant drain on either of these resources whilst his own device 
was not actively engaged in a call. 

A number of lightweight ad ftoc routing protocols have been proposed. The work 
by Toh already discussed describes a wireless communication network, and a scheme to 

15 maximise the battery life of ad hoc devices in the network. S Singh, M Woo and C 
Raghavendra, have made a detailed study of power-conservation in ad hoc networks at 
the MAC and network layers (Tower-Aware Routing in Mobile Ad hoc Networks". 
Proceedings of the Fourth Annual ACM/IEEE International Conference on Mobile 
Computing and Networking (MobiCom), (Dallas, TX, Oct. 1998)). They include schemes 

20 for devices to power-down in between expected transmissions, and they take into account 
device load as an important factor in power consumption. Their main concern is to 
prevent network partitioning when gaps appear in the network as a result of devices 
running out of battery power. Work by WB Heinzelman, AP Chandrakasan and H 
Balakrishnan considers sensor networks specifically. ("Energy-Efficient Routing Protocols 

25 for Wireless Microsensor Networks', Proceedings of the 33rd International Conference on 
System Sciences (HICSS W), January 2000). This work assumes variable device 
broadcast range. Their focus is on the use of clustering techniques to reduce bandwidth 
usage by, for example, data aggregation of similar data, and using predictable 
transmission times, co-ordinated by the cluster heads. This approach saves significant 

30 energy, compared with an always-on approach, but the routing side is simplistic and not 
fully developed. In particular, their experimental scenario assumes the devices could all 
broadcast to the base station if they chose to do so, which would not be realistic, in 
general, for sensor network applications. Wori^ by A Cerpa, J elson, D Elstrin, L Girod, M 
Hamilton and J Zhao, refers to habitat monitoring as a driver for wireless communications 

35 technology, and focuses on power-saving by having devices switching themselves on and 
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off according to whether they are in the vicinity of regions where interesting activity is 
expected, or detected by other devices. ("Habitat Monitoring: Application Driver for 
Wireless Communications Technology", ACM SIGCOMM Workshop on Data 
Communications in Latin America and the Caribbean, Costa Rica, April 2001. Wori< by Y. 
5 Xu, J. Heidemann, and D. Estrin again focuses on using powered- down modes for 
devices to conserve power, based on whether payload data is predicted or not, and on 
the number of equivalent devices nearby that could be used for alternate routing paths. 
("Adaptive energy-conserving routing for multihop aof hoc networks", Tech. Rep, 527, 
USC/lnfonnation Sciences Institute, Oct. 2000) The assumption here is that the underlying 

10 routing will be based on conventional ad hoc routing protocols such as the AODV system 
already discussed. Sensor networks, however, typically would require a lighter weight 
approach to routing, where decisions are based on information from immediate 
neighbours only, and this knowledge needs to be conveyed succinctly, ideally as part of 
the packet headers for the actual data to be collected. 

15 A lot of work has been done at the University of California and the Intel Berkeley 

Research Lab, to develop operating systems and networks for small ad hoc sensor 
devices, known as the Smartdust project, for which an operating system known as 
TinyOS has been developed (DE. Culler, J Hill, P Buonadonna, R Szewczyk, and A Woo. 
"A Network-Centric Approach to Embedded Software for Tiny Devices". DARPA 

20 Workshop on Embedded Software, However, the routing scheme they refer to is not 
power-aware, but rather uses a hierarchical structure to find shortest paths to the sinks. 

So, in summary, there are established routing protocols for ad hoc networks that 
are too resource-intensive for sensor networks and are not power-aware; there are power- 
25 aware metrics which have not been applied to ad hoc networi<s; there are power-aware 
strategies for ad hoc sensor networks that do not optimise the routing; and there Is an 
extensive ad hoc sensor network project without power-aware routing. Note that none of 
this prior work refers to highly mobile ad hoc devices, of the kind to which this invention is 
particulariy directed. 

30 As already discussed, prior art routing mechanisms require far more memory and 

processing power than is suitable for lightweight environmental sensor devices, or 
assume all devices can communicate directly with the sinks. Also, only the full ad hoc 
protocols can cope with device mobility, and these require a large communication 
overhead. 
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Because the devices are moving rapidly, even their nearest neighbours may 
change t)etween data transmissions. Routing decisions must be made *on-the-fly', using 
very recently gathered information. 

In this specification, the term "payload data" is used to mean the useful data 
5 which it is desired to transmit, as distinct from overhead data used to control routing of the 
payload data. Note that there Is some degree of overlap between the two types of data: 
for example the position of the device is necessary for routing purposes, but Is also likely 
to be an important part of the infomrtation collected by the sensor for example in the study 
of ocean currents or animal migratory behaviour. 
10 According to the invention, a mobile data wireless relay device is provided, the 

device having 

receiving means for receiving payload data from a data source, 
a buffer for storing payload data for subsequent transmission, 
means for receiving status data from similar devices, 
15 status data generation means for generating status data, the status data being 

derived from the quantity of data in the buffer store and the status data received from 
other devices, and comprising data relating to 

the position of the device, 
the quantity of data in the buffer store 
20 a scalar fonvarding value {3i and 

a forwarding direction, 
status transmitter means for transmitting status data to other devices 
selection means for identifying from the status data a receiving device to which 
the payload data is to be fooA^arded, the receiving device being located in a position 
25 indicated by the fonwarding direction, 

payload transmission means for transmitting the payload data to the receiving 

device. 

The wireless relay device may include means for receiving payload data 
transmitted by other similar devices, or it may be associated with a data source such as 
30 an environmental sensor. Preferably it can perfomi both functions. Note that some data, 
for example position data, may be both payload and status data. 

jhe selection means may be an^anged to only identify a suitable receiving device 
if the scalar fonwarding value meets a threshold criterion 

The device may include condition-monitoring means for monitoring the expected 
35 lifetime of the device, and adjusting the scalar fonA/arding value accordingly. 
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In a preferred arrangement, the wireless relay device defines a positive node and 
a negative node, the nodes being spaced apart by a distance detemiined by the amount 
of data stored in the buffer, the positive node being assigned a positive value for an 
attribute q and the negative node being assigned a negative value for the attribute q, 
5 equal in magnitude to that assigned to the positive node, 

the wireless relay device has means for receiving data broadcast by similar 
wireless relay devices identifying the position data and attribute values of nodes defined 
by the similar wireless relay devices, 

means for generating fon^farding position values for the positive and negative 
10 nodes based on the attribute values of its own nodes and the positions and attribute 
values of the nodes defined by the neighbouring devices, 

means for transmitting the fonwarding position data and attribute values to similar 

wireless relay devices 

means for transmitting payload data to devices that are in the general direction of 

1 5 the foHA/arding position of the negative node. 

The devices to which payload data is to be transmitted may identify themselves 
by any suitable means, such as individual call signs. The position data of the nodes will 
identify which devices are in the appropriate direction. Similarty, payload data will be 
received by a device according to the invention from similar devices, which will have 

20 identified rt as being in the general direction of their own negative nodes. 

Preferably, the positions of the positive and negative nodes are detennined by 
determining the position in which the aggregate value of the products of the attribute 
values of each node with each node of one or more neighbouring devices, and some 
arithmetical function of the distance between them, is a minimum or maximum. In the 

25 embodiment to be described, the simple reciprocal of the distance is used. 

The spacing between the positive and negative nodes defined by the device is 
preferably on a similar scale to, but not larger than, the transmission range of the device. 

The payload data may be received from another similar device, or generated by 
the device itself. Some or all of the wireless relay devices may therefore comprise data 

30 gathering equipment for generating new data for transmission. In the prefen-ed 
embodiment each data collection device can also act as a wireless relay devices to 
retransmit data received from other such devices. However, the scope of the invention 
does not exclude the presence in the network of some devices that can only transmit data 
to other devices. Any such device would act as a "source" or "negative sink", and would 

35 be defined by a single node with a negative attribute q. 
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Devices capable of interacting witli tlie wireless relay devices may also be 
provided, capable only of reception. They act as information "sinks^ and would typically 
be used as the interfaces between the mobile data gathering network and the fixed data- 
processing system. Such a device is represented as a single node having a positive 
5 attribute value q. In a prefen^ed arrangement, the sinks are allocated the maximum 
attribute value q, and the mobile devices have attribute values whose magnitudes are 
sub-maximal. 

A pair of devices, acting in isolation, would tend to align their node pairs such that 
all four nodes (three nodes if one of the devices is a source or a sink) define a straight 

10 line, with the negative node of one of the devices adjacent to the positive node of the 
other. If there are more than two devices, they will interact in a more complex manner, the 
alignments of the nodes of each device being determined not only by the direction of each 
neighbouring node and the sign of its attribute value, but also by the distance between the 
nodes and the magnitudes of their attribute values. 

15 The wireless relay devices therefore define a preferred direction for payload data 

to travel, namely from the negative node of one device towards the positive node of 
another. If one Imagines a line of devices with a sink at one end, the device closest to the 
sink can express the direction of the sink from itself by the alignment of its positive and 
negative nodes. The next device in the line may be too far from the sink to be able to 

20 transmit directly to it, but can align its node pair with the forwarding direction of the device 
closest to the sink. Specifically it will be aligned with its negative node closest to the 
positive node of the first device, and so on, along the line of devices. Consequently, even 
the device at the furthest end of the line can set its forwarding direction so as to join the 
path to the sink. 

25 In a real two- or three-dimensional system, devices will not fomn simple chains 

but will fomi branched chains converging on the sink or sinks. In order to accommodate 
the influence on each device of several other devices, the local fooA/arding direction is 
chosen to be the sum of all the alignment influences from its nearest neighbours. The 
orientation which produces the optimum value is defined as the local fonvarding direction. 

30 Note that this takes into account not only the position and alignment of devices to which 
data may be sent, but also of those from which it may be received. 

Preferably a fonvarding trigger value is calculated, to determine whether payload 
data should be forwarded. This trigger value determines whether a chain has been 
formed, and therefore whether it is worthwhile to fonvard data. This computation depends 

35 on the use of a further attribute, 3, which is essentially a variable part of the attribute value 
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q, and depends on the proximity, and attribute values, of neighbouring devices. In the 
preferred embodiment battery level is used as a further detemiinant, to ensure that 
devices whose batteries are depleted fonvard their data with greater urgency than those 
with more battery life remaining. Simulation results show that setting a trigger level 
5 delivers a significantly higher proportion of data back to the sinks than a method that relies 
only on fonn^arding towards the nearest sink. 

The devices have no information about whether they are In fact in a chain leading 
to a sink - they simply pass data to a neighbour If certain conditions are met. As the 
devices are mobile, from time to time they may find themselves at locations from which no 

10 viable chain can be defined towards a sink. In such cases data can be stored in their 
buffers until communication is re-established. Since the attribute value q is determined by 
the size of the buffer (or by the available space in the buffer), one device having a full 
buffer may forward data to another device having more space, even though the receiving 
device Is cunrently unable to fonA^ard it. This makes more space available in the buffer of 

15 the transmitting device, allowing it to collect more data either from other devices or from 
its environment The receiving device would retain the transfenred data until it in turn can 
fonvard it 

The wireless relay devices may use directional antennas for transmission and 
reception of data signals. However, because the alignments selected are based on the 

20 aggregate influence of several neighbouring devices, the antennas would have to be of 
relatively wide beam width. This could be achieved using a multi-sectored antenna with an 
integrated beam-forming and switching circuit that allows the antenna to form a number of 
discrete beams, which can be selected individually or in groups to transmit and receive in 
a specific direction, or can all be combined to provide omni-directional coverage. It would 

25 then be possible to detemiine the direction of send signal, as long as devices had a 
reference direction (digital compass). Such a system would not require mechanical 
rotation (with the consequent power and wear implications) However, although such 
antenna an-ays are commercially available, they are cun-ently too large and expensive for 
the cheap devices envisaged. Moreover, although the positions of the nodes defined with 

30 respect to each device may be varied according to the positions and other characteristics 
of the neighbouring devices, the physical orientation of the device itself is not affected. 
The physical orientation is detemnined by the forces causing it to move through its 
environment, such as ocean or wind cunrents, or the behaviour of the object to which it is 
attached, such as an animal whose migratory behaviour is under study. If directional 
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antennas are used, means for accommodating the essentially random orientation of the 
device would need to be provided. 

Although they would reduce the power consumption required for transmission, 
directional antennas would therefore be difficult to accommodate and control in very small 

5 devices. In a prefenBd embodiment each wireless relay device has an address code to 
which data intended for that device should be sent. This address code may be a digital 
code, for example a CDMA chopping code. It may Instead be a radio frequency or time 
slot allocated to that device on which it will listen out. Each device broadcasts its address 
code as well as its position and other attributes. Thus any neighbour selecting it. 

10 according to its direction and distance, as a target to which pay load data should be 
transmitted can identify it by specifying its address. Each device is arranged to only 
receive data directed to its own address. Given that battery power considerations impose 
a relatively limited transmission range on the devices, addresses may be duplicated 
provided that the probability of two duplicate addresses occuning within range of a single 

15 transmitting device is low. 

According to another aspect of the invention there is provided a network of 
wireless relay devices comprising a plurality of mobile wireless relay devices capable of 
receiving payload data, and each having means for identifying a forwarding direction 
relative to itself, and means for transmitting data to another of the devices whose current 

20 position is in the said fonA^arding direction and within a predetermined distance, wherein 
the devices co-operate to define their forwarding directions such that payload data is 
transmitted to a target sink device by means of one or more of the wireless relay devices. 

According to a further aspect, there is provided a method of operating a plurality 
of mobile data wireless relay devices, comprising: 

25 collecting data in buffer stores in one or more such devices, 

exchanging status data between the devices, the status data comprising data 
relating to 

the positions of the devices, 
the quantity of data in their buffer stores 
30 each device defining, from the status data, a fonvarding direction towards which 

the payload data in its buffer store is to be fonvarded, 

transmitting the stored payload data to a device located in the fonAfarding 
direction. 

This invention provides a wireless relay device that not only identifies a 
35 transmission hop in the right direction, but fonA^ards payload data to the neighbouring 
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device giving the best chance of its data getting all the way back to a data sink. It requires 
no explicit knowledge of the topology of the network, and in particular requires no details 
of any hop other than the one it is directly connected to. A complete route back to a sink 
is given by a chain of wireless relay devices, where each wireless relay device is within 
5 fonA/arding range of the previous device in the chain. Such a structure may only exist 
quite briefly, as the devices move around. Indeed, the complete chain may not all exist at 
the same time, the Individual hops coming into existence at different times as the devices 
move around. 

The invention could also be used to route packets in multi-hop cellular networks 

10 to a nearby base station. No sensor-network-specific assumptions are made, e.g. that all 
nodes generate data. Extension to general ad hoc networks, where any node can send to 
any other, would involve the nodes maintaining a number of forwarding directions, for 
different target nodes. In order to overcome scaling difficulties, in such a case, the nodes 
could be organised into hierarchical clusters, with nodes needing to have forwarding 

1 5 directions to forward to cluster-heads and to nodes within their own clusters. 

The invention allows the collection of data from an ad hoc network of highly 
mobile sensor devices, to one or more "sink" devices, which may also be mobile, in a way 
that is distributed, robust and lightweight. 

Preferably the routing takes account of the battery and memory levels of 

20 participating devices, so that devices which are low on resources are less heavily loaded. 
However, only information from a device's immediate neighbours is available, so any 
decisions taken must be done on the basis of only a few parameters from a handful of 
nearest neighbours. This is because of the constraints on the devices' processing power 
and memory, as well as bandwidth which is severely limited as a result of small, finite 

25 battery power. 

An embodiment of the invention will now be described, by way of example only, 

with reference to the Figures in which 

Figure 1 1s a schematic diagram of a device according to the invention 

Rgure 2 is a diagram of part of an ad hoc network made up of devices of the kind 

30 shown in Figure 1 

Figure 3 is a flow chart showing the processes performed by an individual device, 
and the information it exchanges with similar devices, in order to detennlne the cunrent 
values for the parameters used in the invention 
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Figure 4 is a further flow chart, showing the processes used to identify a 
destination device and to transmit data to it. using the parameters generated in the 
process of Figure 3. 

Figure 1 shows a device 20 according to the invention. It comprises a wireless 

5 transmitter 21 and a wireless receiver 22, and data collection means 23 whidi include 
position sensors, and environmental or physiological sensors for detemiining properties of 
the environment of the device, or of some object to which it is attached. There is also a 
data buffer 24 for storing payload data (that is to say, data that is to be transmitted to a 
destination for processing) and a data store 25 for operational data (that is to say. data 

10 required for the operatiln of the device and in particular for controlling the transmission of 
the payload data). There is also computation means 26 for processing the data collected 
by the data collection means 23 and stored in the data buffer 24, and control means 27 for 
controlling the operation of the device in response to outputs from the computation means 
26. The device is powered by a battery 28 whose condition is monitored and the results 

15 stored , in the data store 25 with other operating parameters. The power connections 
themselves are not depicted in this schematic diagram). 

Figure 2 shows a network comprising several devices 1 0, 20, 30, 40, 50, 60, 70, 
80. each of the type shown in Figure 1 . These devices are firee to move relative to each 
other through their environment, collecting data from their environment such as 

20 temperature, barometric pressure, salinity etc). They also record their position. They may 
be canied by inanimate forces such as ocean or air curents, lava or glacier flows, or they 
may be attached to animals or human beings to track their movements or physiology, or to 
a vehicle to monitor its progress on a journey or to locate it if it is reported to have been 
stolen. 

25 The devices 10, 20, 30, 40 etc shown In Figure 2 form an acf hoc wireless 

network 19, 29, 39. 49, etc. The wireless connections may use radio communications, or 
any other transmission medium suitable for the environment in which the devices are 
expected to operate. For example, acoustic (sound) waves are suitable for water-bome 
devices used to study oceanography and ichthyology. Data collected by a device 20 

30 (either by its own sensors 23, or relayed from another device 10) is transmitted to a 
destination 90 either directly or by means of one or more other devices 30. These other 
devices may also collect data. The destination 90 is a fixed receiver station, which will be 
referred to as an infonnation "sink", and which collects data collected by the mobile 
temiinals 10, 20, 30 etc for subsequent processing. There may be more than one sink in 

35 the network. The sink device 90 is more powerful than the sensor devices 10, 20 30 etc, 
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both in terms of processing capability and power-consumption, and either have long-term 
storage facilities for the data, or a long-range transmission link 98 to a data-processing 
centre 99. The sensor devices 10, 20, 30 themselves have very limited battery power 
(allowing only short-range wireless transmissions), small processors and limited memory. 
5 As the devices 10. 20 etc move around, the wireless links 19, 29, 39 etc between 

• them have to re-arranged in order to provide the optimum networlc. As well as physical 
location, Actors such as the spare capacity of the buffer store 24 and the battery 28 are 
taken into account in determining whether a wireless link 29 should be established 
between two devices 20, 30. The process by which this Is done will be described in detail 
10 shortly. 

When a device 20 has identified a device 30 to which data can be forwarded, it 
retrieves data from its buffer 24 and transmits it to the target 30. The device 30 then 
repeats the process of identifying a suitable neighbour and so on, until the data reaches 
the sink 90. If no suitable device is identified, the data is stored in the buffer 24 until the 

15 movements of the devices brings a suitable device into range. 

In general, it is desirable that the devices transmit data in the general direction of 
the nearest sink 90. Thus when two devices 20. 30 come into proximity to each other, a 
direction 200 needs to be determined to identify which device 20 should transmit data and 
which device 30 should receive it. This direction 200 will be referred to as the "fonA/arding 

20 direction" for a given device 20, and defines a receive end 201 and a transmit end 202 for 
the device 20. The device also detemiines whether to forward data to the nearest 
neighbour 30 whose location is in this direction, based on the separation of the devices 
20, 30, and other characteristics, as will be described in detail later. 

If a sink 90 is within direct transmitting range (as for example Is illustrated for 

25 device 30), the fonA^arding direction will be towards the sink. Any device 20 which is not in 
range of a sink are an^anged to align its fonA/arding direction 200 towards the receive end 
of one or more neighbouring devices 30. Thus a network 1 9, 29, 39 etc will be defined, 
each device having its transmit end aimed in the direction of the receive end of the next 
device until they reach a sink. 

30 The operation of this embodiment will now be described, with reference to 

Figures 3 and 4. 

Each mobile device (20 etc) initially measures and stores a number of attributes 
relating to itself (step 31 1). These attributes are: 

Buffer size Ax a scalar quantity representing the amount of data awaiting transmission, 
35 expressed as a fraction of the total capacity of the buffer 24. 
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Battery charge remaining. Bx another scalar quantity representing the expected life of the 
device 

Position . Px a pair of co-ordinates (or a triplet if three dimensions are needed) The 
position will be known since environmental sensors need to be able to determine their 

5 position for the data they collect to be useful. Each device may have means such as a 
GPS (Global Positioning System) sensor for this purpose. Alternatively, provided at least 
one device can detennine Its absolute position, the absolute positions of all the others can 
be derived, as discussed in International Patent Specification WO03/1 07595 which 
provides a method of estimating the location of a device within a network of devices each 

10 of which forms a node of the network, the method including the steps of: 

obtaining infonnation specifying the location or estimated location of one or more 

neighbouring nodes; 

measuring the distance to said one or more neighbouring nodes; and 

iteratively modifying an estimated location of the device, such as to improve the 

15 consistency between the estimated location of the device and the location or estimated 
location of the one or more neighbouring nodes, as detemriined from the obtained 
Information specifying the location or estimated location of the one or more neighbouring 
nodes, on the one hand and the measured distances to each of the one or more 
neighbouring nodes on the other hand. 

20 Using the values Ax, Bx and Px the positions and other attributes are defined 

(step 312) for two virtual nodes 201, 202, referred to herein as the positive node and the 
negative node. The nodes are constrained to be located at diametrically opposed points 
P+ P. on a circle 23 (or a sphere in a three dimensional embodiment) centred on the 
device 20. The diameter dx of the circle is a function of the buffer size Ax. Thus the actual 

25 position Px of the device 20 is the mid-point of a line of length d joining the positions P+ P. 
of the two nodes. The orientation of this line is initially arbitrary (it may be defined with 
reference to the device itself or a compass bearing, or a previous position), but it 
subsequently takes up a position 200 determined by the properties of neighbouring 
devices 10, 30, 40 etc. 

30 The nodes 201 , 202 represent an input direction and an output direction for the 

device 20. These are the directions respectively in which data is to be fonwarded, 
respectively, to and from the device 20. However, it should be cleariy understood that the 
nodes 201, 202 are purely points in space, defined with respect to the relative positions of 
the device 20 and its neighbours. Unless directional antennas are to be used, it does not 

35 relate to the actual orientation of the device itself, which may be changing rapidly for 
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example if the device is in a turbulent fluid. A network sink is represented as a single 
positive node, co-located with the device 90 it represents. 

Each node is attributed an influence value Q+, Q.. This influence value is a 
measure of the ability of that node to influence the nodes of other devices 10, 30. 40 etc. 

5 The positive node of each mobile wireless relay device has an activity value Q+ whose 
value is a positive number. The output end has a negative activity value Q_^=-Q+ equal in 
magnitude to the influence value of the positive node. The scalar magnitude of the 
influence values of the node pair has two components: an intrinsic component q which is 
simply a function of the buffer size Ax, and is independent of other devices, and an 

10 induced component 8, which is influenced by neighbouring devices. As will be discussed 
later, the value of the induced component 5 depends on the positions and influence values 
of the neighbouring devices, and their ability to be Influenced by other devices ox, which is 
again a function of the buffer size Ax. 

The properties d, q, and a are selected such that the strongest interactions occur 

15 between a device with a full buffer (A = 1) and another device with an empty buffer (A = 
0). The influence value Qsfor a sink 90 is set at the maximum value. In this embodiment 
Qs = 1 , and all other devices have fractional values for Q. These properties could be 
allowed to vary continuously according to the quantity of data in the device's buffer, but to 
reduce the memory and calculation required this embodiment quantifies buffer size as one 

20 of a small number of levels, for example empty, full, and three Intennediate levels - each 
level having a specified value for each property dx, qx, o^x- This requires the devices 20 
etc to store just (5 levels x 3 properties) = 15 values, minimising the memory required of 
the devices. Any device can then detemiine the values of dx, qx, ax for itself, or for any 
neighbouring device, from the buffer size category Ax alone. 

25 In order to calculate the fonA/arding direction for a device X, only the permanent 

components q+, q. of the influence values are used. Initially the induced component 5x is 
set at zero. 

When a device X has data stored in its buffer, it broadcasts a signal (step 313) to 
identify whether any other devices are in the vicinity. Any device 10, 30. 40 detecting this 
30 broadcast responds (step 314) with the positions Py+ Py. of its own node pair, and the 
induced influence component Sy. This is sufficient infomnation to detennine the other 
properties of the node pair - from the positions of the pair of nodes their separation dy can 
be determined, from which can be deduced the buffer category Ay, and hence the 
permanent influence values qy+ , qy. of the two nodes (step 315). 
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Using the position and influence attributes received from its neighbours, a device 



X can then determine a scalar interaction value C/j^ =2] (®*®P ^^^^ ^^^^ 



nodes / of the device perfomning the calculation and all nodes ] of any neighbouyring 
devices 10, 30, 40 etc, and where ry is the distance between node i and node j. W Note 
5 that the value of qi Is the same for each tenn in this summation, except that it is negative 
when considering the negative node, so this formula can be simplified to 



where qx+ is the influence value of the positive node of device X, and rj+ is the distance 
between the positive node of device X and node j of another device, and rj. is the distance 

10 between the negative node of device X and node j of another device. As the nodes are 
merely virtual points in space, it is possible that nodes of neighbouring devices may de 
defined to be at the same point. 

Thus, for each of the two nodes i of the device X under consideration, the 
aggregate value of the Influence attributes of each node j of its neighbours may be 

15 calculated, weighted for distance r. (Since r=0 would lead to an infinite value for Ux. the 
value of T is defined such that it cannot be less than a predetenmined minimum value). 
Note that each neighbouring device will have two nodes to be considered, whose activity 
attributes q+ q. are equal and opposite, but whose distances r from any other given node j 
will generally be different, as one node will be nearer than the other. Thus the number of 

20 interactions to be determined is 4n where n is the number of neighbour devices - each 
neighbour has two nodes, and the interaction of each neighbour node is considered with 
each of the device's own two nodes. 

The orientation 200 of the nodes 201 , 202 In the device Is initially arbitrary: but 
having established a value for Ux the positions of the nodes are now redefined to be 

25 rotated about the centre Px (the actual location of the device X) (step 317) and a new 
value of Ux is calculated (repeat step 316). In the present embodiment eight orientations 
are assessed in this way, spaced at 45 degrees. Note however that the positions of the 
nodes Px+. Fx- are symmetric about the centre Fx. and they differ only in the sign of their 
influence values Q. Consequently only four calculations need to be performed - the other 

30 four have the same magnitudes, but opposite signs. 

An optimum orientation 200 is then detemiined (step 318) - this is the orientation 
giving the minimum value of Ux. This orientation 200 is then maintained for subsequent 
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Steps of the process, and the positions P+ P- of the nodes 201, 202 are stored (step 319) 
for transmission to other devices 1 0. 30, 40 when they request them, to use in their own 
computations. If each device maintained constant values for positions P and buffer states 
A, (and hence influence value Q) their node orientations would eventually reach a steady 

5 state. However, in practice, the devices are moving and transfening data, so these values 
are constantly changing. 

Any device 30 that detects a sink 90 in the vicinity would therefore generate an 
orientation for its node pair whose direction is towards the sinic 90. Such a device 30, in 
turn, has a knock-on effect on other nearby devices 20, 50 that are too far away from the 

10 sink 90 to fonfl^ard to it directly, and these nearby devices 20. 50 will also influence 
devices 10. 40 yet further away from the sink 90, to orient their fonA^arding directions so as 
to make a path to the sink 90, via the intemnediate devices 20. 30 (for example path 19. 
29. 39). The result is that, inrespective of network topology, ail devices (unless entirely cut 
off by distance from regions of the network that have paths to a sink 90) will have a 

1 5 fonvarding direction 200 that is likely to enable transmission of data to a sink 90. 

The aggregate alignment influence of neighbouring devices is therefore 
determined quantitatively, according to the separation of the devices r, and their cun-ent 
prefenred fonvarding directions. In general, a device is likely to be within the influence of 
several other devices, some of which will have conflicting (opposite) influences, and their 

20 effects need to be combined to provide a single fonvarding node pair. Usually, a device 
will be most strongly influenced by the neighbour closest to itself, but will also be 
influenced to a lesser extent by the other neighbours. As will be explained below, other 
factors intrinsic to the devices, in particular the available buffer storage, may not be equal 
for all devices, and these will affect the scalar magnitude (but not the direction) of the 

25 influence value q, reducing or increasing the influence it has on neighbouring devices. 

The alignment, and thus the positions of the nodes P+ P. is recalculated whenever 
the device 20 generates, receives or transmits payload data as this affects the buffer 
capacity Ax . The alignment may also be recalculated periodically as the device 20 and its 
neighbours move if resources are available. 

30 When a device starts a calculation of its alignment, the initial value it uses for the 

position of the negative node is as close as possible to that calculated at the previous 
iteration, subject to the constraint that it must be at a distance d/2 from the position P of 
the device itself. If the device has not moved, the positive node will therefore also be in 
the same position as at the previous iteration. However, if the device has moved the initial 

35 position of the positive node will have moved. Thus the orientation of the device will rotate 
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such that it still points towards the same point in space (the negative node). An alternative 
approach would be to keep the orientation the same, i.e. parallel with its previous 
orientation. 

When the device has data to transmit, (i.e. the buffer 24 is not empty) (step 410) 
5 the device perfomis further computations to determine the strength of interaction 
(alignment influence) between neighbouring nodes, as will now be discussed with 
reference to Figure 4. A strong interaction indicates that fonA^arding is likely to be useful: 
both in terms of proximity of a device with buffer capacity to accept the payload data, and 
also with a good probability of a long-range fonn^arding chain to the sink 90. This is done 
10 by calculating an induced component 6oi the influence value Q, which is itself influenced 
by the influence values cb of neighbouring devices, and is given by 



where S/xs the induced component of Q for a node j of a neighbouring device, is the 

measure referred to above of the degree to which the node X can be influenced, dx is the 
15 spacing between the nodes of device X, and qx is the pennanent influence value of device 
X, all of which values are derived from the buffer size Ax. qj is the influence value of a 
neighbouring node at distance rxj . If this induced value exceeds a pre-set threshold, then 
data is fonwarded to the nearest device to the negative node of the device, provided that 
this neighbouring device is within transmission range. 

20 The induced value. , is compared with a fixed threshold Smm , (step 412) . The 

nearest device 30 to the negative node P. (202) is identified from the position data of the 
neighbours (step 413). The distance r of this device is detemiined (step 414 and 
compared (step 416) with a broadcast range R. A check is made (step 417) to ensure the 
payload data did not originate from the target neighbour device. Lastly, the invention 

25 restricts the choice of influencing neighbouring devices to exclude from consideration any 
subject device from which data has recently been received. This is to stop data "ping- 
ponging" backwards and forwards. Larger loops may occur briefly from time to time, but 
they would be unlikely to persist for long as the relative positions of the sensors change, 
and in the absence of a sink node in the vicinity. 

30 The broadcast range R is detemiined (step 415) according to the ratio of (battery 

power lefl)/(time left), as follows: 




R = range + 



2^, 



max 
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where B is the current battery level and Bq is the initial battery level, and rand t^^ are the 
cunrent time and length of the data-gathering experiment respectively; range is not 

allowed to exceed range„^ . 

If the neighbour device 30 is within broadcast range (r<R) and the other 

5 conditions refen-ed to above are met the payload data is retrieved from the buffer store 24 
and addressed to the neighbour device 30 using its id code (step 418). 

More sophisticated controls could be used, based on the quantity of data left in 
the device buffer, perhaps, but this simple approach has been shown to give advantage 
compared with a range that is independent of battery power, and it is easy for simple 

1 0 devices to calculate. 

If a device 20 is cut off from any path to a sink 90 it can simply store any payload 
data in the buffer 24 until the movements of the devices re-establishes a feasible route. 
FoHAording directions 200 are updated dynamically, so that as soon as a link 29 is re- 
established, transmission of data can re-start. If the network is sparsely populated, such 

15 that nodes are widely separated, most data transmissions may only occur when a 
device20 comes within direct range of a sink 90, In densely populated networks paths 
having a larger number of hops 1 9, 29, 39 will be more common. The process is flexible 
enough to cope with a wide range of circumstances, in terms of network topology and 
device mobility, without such variations requiring special treatment. 

20 Computer simulations of systems of devices according to this invention have 

been found to route data so that less transmission energy is used for fonvarding, more 
data is recovered, and fewer hops are needed than with a simpler approach that always 
chooses to fonfl^ard in the direction of the nearest network sink. The invention has the 
ability to convey longer-range network structural infonnation than would otherwise be 

25 available to the mobile devices, through the interactions of their prefenred forwarding 
directions. 
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CLAIMS 

1 . A mobile data wireless relay device, the device having: 
receiving means for receiving payload data from a data source, 

5 a buffer for storing payload data for subsequent transmission, 

means for receiving status data from similar devices, 

status data generation means for generating status data, the status data being 
derived firom the quantity of data in the buffer store and the status data received from 
other devices, and comprising data relating to 
1 0 the position of the device, 

the quantity of data in the buffer store 
a scalar fonvarding value and 
a foRA^arding direction, 
status transmitter means for transmitting status data to other devices 
15 selection means for identifying from the status data a receiving device to which 

the payload data is to be fonvarded, the receiving device being located in a position 
indicated by the fonAording direction, 

payload transmission means for transmitting the payload data to the receiving 

device. 

20 

2. A mobile data wireless relay device according to claim 1, comprising means for 
receiving payload data transmitted by other similar devices. 

3. A mobile data wireless relay device according to claim 1 or claim 2, further 

* 

25 comprising a data source 

4. A mobile data wireless relay device according to any preceding claim, wherein 
the selection means is an^nged to only identify a suitable receiving device if the scalar 
foHA^arding value meets a threshold criterion. 

30 

5. A mobile data wireless relay device according to any preceding claim, further 
comprising condition-monitoring means for monitoring the expected lifetime of the device, 
and adjusting the scalar forwarding value accordingly. 

6. A mobile data wireless relay device according to any preceding claim, comprising 
35 means for defining a first node and a second node, the nodes being spaced apart by a 
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distance determined by the amount of data stored in the buffer, the first node being 
assigned a positive value for an attribute q and the second node being assigned a 
negative value for the attribute q. equal in magnitude to that assigned to the positive node, 
the wireless relay device has means for receiving data broadcast by similar 

5 wireless relay devices identifying the position data and attribute values of nodes defined 
by the similar wireless relay devices, 

means for generating position values for the first and second nodes based on the 
attribute values of its own nodes and the positions and attribute values of the nodes 
defined by the neighbouring devices, 

10 means for transmitting the position data and attribute values to similar wireless 

relay devices 

means for transmitting payload data to devices that are in the general direction of 
the second node. 

15 7. A mobile data wireless relay device according to any preceding claim, wherein 
the positions of the first and second nodes are detennined by detenmining the position in 
which the aggregate value of the products of the attribute values of each node with each 
node of one or more neighbouring devices, and an arithmetical function of the distance 
between them, is a minimum or maximum. 

20 

8. A networi^ of wireless relay devices comprising a plurality of mobile wireless relay 
devices capable of receiving payload data, and each having means for identifying a 
fonvarding direction relative to itself, and means for transmitting data to another of the 
devices whose cun^ent position is in the said fonwarding direction and within a 

25 predetermined distance, wherein the devices co-operate to define their fonvarding 
directions such that payload data is transmitted to a target sinl^ device by means of one or 
more of the wireless relay devices. 

30 

9. A networt< of wireless relay devices according to claim 8, wherein each device 
defines a positive receive node and a negative transmit node, spaced a predetemiined 
distance apart, and the devices co-operate to define the positions of the nodes so as to 
minimise the aggregate distances between nodes having opposite signs, and wherein the 
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forwarding direction of each device is defined as the direction from its receive node in 
which its transmit node lies. 

10. A method of operating a plurality of mobile data wireless relay devices, 

5 comprising: 

collecting data in buffer stores in one or more such devices, 

exchanging status data between the devices, the status data comprising data 

relating to 

the positions of the devices, 
1 0 the quantity of data in their buffer stores 

each device defining, from the status data, a forwarding direction towards which 
the payload data in its buffer store is to be fonA^arded, 

transmitting the stored payload data to a device located in the fonwarding 

direction. 

15 

11. A method according to claim 10, wherein data is only transmitted from a first 
device to a second device located in its forwarding direction if a scalar fon^^arding value 
derived from the status data exceeds a predetemnined value. 

20 12, A method according to claim 10 or 1 1 . wherein the status data includes a measure 
of the expected lifetime of the device. 

13. A method according to claim 10, 11 or 12, wherein each device defines a first 
node and a second node, the nodes being spaced apart by a distance detennined by the 

25 amount of data stored in the buffer, the first node being assigned a positive value for an 
attribute q and the second node being assigned a negative value for the attribute q, equal 
in magnitude to that assigned to the positive node, 

generating position values for the first and second nodes based on the status 
data of the device and neighbouring devices, 
30 transmitting the position data and attribute values to similar wireless relay devices 

transmitting payload data to devices that are in the general direction of the 
second node. 

14. A method according to claim 13, wherein the positions of the first and second 
35 nodes are detentiined by detemiining the position in which the aggregate value of the 
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products of the attribute values of each node with each node of one or more neighbouring 
devices, and an arithmetical function of the distance between them, is a minimum or 
maximum. 

5 15. A method according to claim 14, wherein the devices co-operate to define the 
positions of the nodes so as to minimise the aggregate distances between nodes having 
opposite signs, and wherein the forwarding direction of each device is defined as the 
direction from its receive node in which its transmit node lies. 

10 16. A method according to claim 13. 14 or 15 wherein the devices co-operate to 
define their fonfl^arding directions such that payload data is transmitted, by means of one 
or more of the wireless relay devices, to a target sink device defined by a receive node. 
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